package temp.leetcode.editor.cn;

//给你一个整数数组 nums ，数组中的元素 互不相同 。返回该数组所有可能的子集（幂集）。
//
// 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。
//
//
//
// 示例 1：
//
//
//输入：nums = [1,2,3]
//输出：[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]
//
//
// 示例 2：
//
//
//输入：nums = [0]
//输出：[[],[0]]
//
//
//
//
// 提示：
//
//
// 1 <= nums.length <= 10
// -10 <= nums[i] <= 10
// nums 中的所有元素 互不相同
//
//
// Related Topics 位运算 数组 回溯 👍 2007 👎 0

import java.util.ArrayList;
import java.util.List;

/**
 * 子集
 *
 * @author saint
 */
class P78_Subsets{
    public static void main(String[] args) {
        Solution solution = new P78_Subsets().new Solution();

    }

    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    List<List<Integer>> res = new ArrayList<>();
    List<Integer> comb = new ArrayList<>();
    public List<List<Integer>> subsets(int[] nums) {
        backtracking(nums,0);
        return res;
    }

    public void backtracking(int[] nums,int begin){
        res.add(new ArrayList<>(comb));
        if (begin == nums.length){
            return;
        }

        for (int i = begin; i < nums.length; i++) {
            comb.add(nums[i]);
            backtracking(nums,i+1);
            comb.remove(comb.size()-1);
        }
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
